草庐IT

C++ union 与 reinterpret_cast

全部标签

c# - FlatBuffers:使用 union 发送多种数据包类型

我将通过连接发送多种缓冲区类型。为简单起见,想象一个类似这样的模式:namespaceMyEvents;tableEventOne{id:uint;timestamp:ulong;adress:string;}tableEventTwo{id:uint;timestamp:ulong;strength:float;}unionEvents{EventOne,EventTwo}tableEventHolder{theEvent:Events;}root_typeEventHolder;我为C++和C#生成所需的文件,并根据需要将它们包含在我各自的项目中。下面是我在C++中编码事件的方式-

c++ - 为什么这个来自Objective-C++的dynamic_cast调试成功但发布失败?

我在最新版本的Xcode(撰写本文时为9.4.1)中构建了一个C++框架,我再次在Xcode中从Objective-C++代码中使用它。我需要执行从一种指针类型到另一种指针类型的dynamic_cast。但是,dynamic_cast仅适用于调试版本,不适用于发布版本。关于dynamic_cast在Objective-C++中的工作方式,我是否缺少或理解导致此示例失败的某些内容?C++框架TestClass.hppclassParent{public://https://stackoverflow.com/a/8470002/3938401//musthaveatleast1virtu

c++ - 匿名空无标记类、结构、 union 和枚举

!免责声明!:请注意,我说的是未标记声明。我知道这可能是一个非正式术语,我的意思是声明不是typedef并且它不声明匿名类型的对象。在这些情况下,一切都很清楚。问题一:以下哪个是格式正确的C++程序?(多选)//Oneintmain(){struct{};//orclass{};shouldbethesame}//Twointmain(){enum{};}//Threeintmain(){union{};}备注:MSVC9.0接受所有这三个。在第一位,它给出了警告。在第二和第三,我们得到0个错误和0个警告。在线comeau仅接受三号,一号和二号无法编译,并显示诊断消息“声明未声明任何内

c# - 如何将带有 const char* 的 C union 映射到 C# 结构?

在本地库的回调函数中,我需要访问一个espeak_EVENT数组。问题出在原C代码中的UNION语句:typedefstruct{espeak_EVENT_TYPEtype;unsignedintunique_identifier;//messageidentifier(or0forkeyorcharacter)inttext_position;//thenumberofcharactersfromthestartofthetextintlength;//wordlength,incharacters(forespeakEVENT_WORD)intaudio_position;//th

c++ - static_cast 如何与虚拟继承一起使用?

因此不可能使用具有虚拟继承的static_cast进行向下转型,但是如何进行以下向上转型:classBase{...};classDerived:publicvirtualBase{...};...Derived*d=newDerived();Base*b=static_cast(d);对象的内存布局:[derivedpart|basepart]我知道向上转型被认为是“安全的”,但是当继承是虚拟的时,编译器如何在编译时知道基础子对象的偏移量?static_cast是否使用vtable?当我们有这样的东西(注意它不是虚拟的)时,这尤其令人困惑:classThird:publicDeriv

c++ - union 体的活跃成员,统一的初始化和构造函数

作为(WorkingDraftof)C++Standard说:9.5.1[class.union]Inaunion,atmostoneofthenon-staticdatamemberscanbeactiveatanytime,thatis,thevalueofatmostoneofthenon-staticdatamemberscanbestoredinaunionatanytime.[...]Thesizeofaunionissufficienttocontainthelargestofitsnon-staticdatamembers.Eachnon-staticdatamembe

c++ - std::move into static_pointer_cast:为什么 static_pointer_cast 没有右值引用重载?

假设我们有一个函数需要一个按值共享的指针。(在现实生活中的例子中,我通过右值引用获取它并将其转发给成员。)voidf(std::shared_ptrptr){...}但是我们只有一个指向基类的共享指针,所以我们使用static_pointer_cast:std::shared_ptrptr=std::make_shared();f(std::static_pointer_cast(ptr));第一个赋值(从临时构造ptr)是否触发了引用计数的原子递增和递减,或者共享指针是否被移动?(请注意,它正在向上转换。)在static_pointer_cast中有引用计数的原子增量。如果我们不再需

c# - 与 COM 中的 QueryInterface 或 C++ 中的 dynamic_cast 相比, "as"的成本是多少?

我仍在尝试将我深厚的旧知识从C/C++映射到我较浅的.Net知识。今天是时候在C#中使用“as”(隐含地“is”和cast)了。我对“as”的心理模型是,它是一个QueryInterface或dynamic_cast(一个带有指针参数的dynamic_cast,而不是引用,也就是说)对于C#。我的问题有两个方面:我的比较公平吗?与QueryInterface或dynamic_cast相比,“as”的相对成本是多少? 最佳答案 是的,比较是公平的,尤其是在处理指针时。这三个中的每一个要么成功并返回目标类型的非空指针,要么返回null。

c++ - C++ union 中的两个数组

是否可以像这样在union中共享两个数组:struct{union{floatm_V[Height*Length];floatm_M[Height][Length];}m_U;};这两个数组共享相同的内存大小还是其中一个更长? 最佳答案 两个数组必须具有相同的大小和布局。当然,如果你使用m_V初始化任何东西,那么所有对m_M的访问都是未定义的行为;例如,编译器可能会注意到m_V已更改,并返回较早的值,即使您已经通过m_M修改元素。我实际上使用了一个编译器这样做,在遥远的过去。我会避免访问union是不可见的,比如传递对m_V的引用和

c++ - 为什么全局匿名 union 需要声明为静态的?

C++0xdraft9.5.6Anonymousunionsdeclaredinanamednamespaceorintheglobalnamespaceshallbedeclaredstatic.这是为什么? 最佳答案 假设匿名union不需要声明为静态的,并且编译器遇到这两个翻译单元(预处理后):文件1:union{inta;charb;};//Furthercontentsreferringtoaandb文件2:union{inta;charb;};//Further(different)contentsreferringto